java - 将 .txt 文件读入二维数组
全部标签 有时我希望一个变量始终是一个数组,无论它是一个标量还是已经是一个数组。所以我通常这样做:[variable].flatten与ruby-1.8.5、1.8.7、1.9.x兼容。当variable是一个字符串(variable="asdf")时,使用此方法,它会给出["asdf"]。如果它已经是一个数组(variable=["asdf","bvcx"]),它会给我:["asdf","bvcx"]。谁有更好的办法?“更好”意味着更易读、更高效、更简洁或在其他方面更有效。 最佳答案 Array(variable)应该可以解决问题。它使
我目前正在编辑一个文件,我正在使用irb来测试api:>require'./file.rb'>o=Object.new>o.method然后我希望能够编辑file.rb,并能够立即看到更改。示例:假设当我第一次需要file.rb时new_method不存在:>o.new_method这将返回一个错误。是否有沙盒/开发人员模式或方法可以实现上述目标而不必每次都重新加载文件?无论如何,在第一个要求之后要求将不起作用。我假设最坏的情况是我不得不改用负载。 最佳答案 我通常会像这样创建一个简单的函数:defreloadload'myscri
我想复制一个数组,在不影响原始数组的情况下就地修改副本。此代码失败a=['462664','669722','297288','796928','584497','357431']b=a.cloneb.object_id==a.object_id#=>falsea[1][2]='X'a[1]#66X722b[1]#66X722副本应该不同于对象。如果它只是一个引用,为什么它表现得像? 最佳答案 您需要对数组进行深拷贝。方法是这样的Marshal.load(Marshal.dump(a))这是因为您克隆的是数组而不是其中的元素。所以数
ruby1.8.6我有一个包含数值的数组。我想减少它,以便将相同值的序列减少为该值的单个实例。所以我想a=[1,1,1,2,2,3,3,3,3,2,2,2,3,3,3]减少到[1,2,3,2,3]如您所见,Array#uniq在这种情况下不起作用。我有以下有效的方法:(a.size-1).downto(1){|i|a[i]=nilifa[i-1]==a[i]}谁能想出不那么丑陋的东西? 最佳答案 对于最简单、最精简的解决方案,您可以使用方法Enumerable#chunk:a.chunk(&:itself).map(&:first)
我正在使用RubyonRails3.1,我想知道如何正确处理与部分模板文件相关的国际化。也就是说,......在我的app/views/users/flag.html.erb文件中我有:"/users/flag_form"%>...在我的app/views/users/_flag_form.html.erb文件中我有:如果在我的config/locales/views/users/en.yml文件中(注意:我按照officialRoRguide中的说明组织文件)我使用en:users:flag:test_key1:Test1texttest_key2:Test2text测试1文本显示在
我正在编写一个单元测试,其中一个正在返回一个zip文件,我想检查这个zip文件的内容,从中获取一些值,并将这些值传递给下一个测试。我正在使用机架测试,所以我知道我的zip文件的内容在last_response.body中。我查看了RubyZip的文档但它似乎总是期待一个文件。由于我正在运行单元测试,因此我更愿意在内存中完成所有操作,以免测试zip文件污染任何文件夹,如果可能的话。 最佳答案 马特的回答完全正确。此处更新为新的API:Zip::InputStream.open(StringIO.new(input))do|io|whi
我有一个字符串,里面有一个数组:"[[1,2],[3,4],[5,6]]"我可以将其转换为数组的数组,而不使用eval或正则表达式、gsub等吗?我可以把它变成:[[1,2],[3,4],[5,6]] 最佳答案 下面的怎么样?require'json'arr=JSON.parse("[[1,2],[3,4],[5,6]]")#=>[[1,2],[3,4],[5,6]]arr[0]#=>[1,2] 关于ruby-如何将字符串转换为数组数组?,我们在StackOverflow上找到一个类似的
我想从类似http://testasp.vulnweb.com/avatars/noavatar.gif的uri中找到像.gif、.jpg、.txt这样的文件扩展名. 最佳答案 可以使用File的extname方法url="http://testasp.vulnweb.com/avatars/noavatar.gif"File.extname(url)#=>.gif 关于ruby-on-rails-如何从Rails应用程序的URI获取文件扩展名,我们在StackOverflow上找到一个
如何使用Ruby打开文件并在其中搜索单词? 最佳答案 所有提出的解决方案的时间复杂度都是O(n)。为简单起见,我使用String#include?来检查单词。这可以用string=~regex形式的正则表达式代替。阅读完整文件并在其中搜索。File.read(filename).include?(word)如果您的文件非常大,这不是最佳解决方案,因为您会将整个文件读入内存,然后再开始搜索。你的内存复杂度是O(n)逐行读取文件并在每一行中搜索File.open(filename)do|f|f.any?do|line|line.incl
Ruby中的范围非常酷。我最终得到这样的数组:geneRanges=[(234..25),(500..510),(1640..1653)]然后必须删除其中的一部分。为此我:genePositions=geneRanges.collect{|range|range.entries}.flatten=>[500,501,502,503,504,505,506,507,508,509,510,1640,1641,1642,1643,1644,1645,1646,1647,1648,1649,1650,1651,1652,1653]它们会被操纵,因此一些数字被排除在外,而另一些可能会被添加。我